// pages/login/login.js
import request from '../../utils/request'
Page({
  /* 
    登录流程：
      1. 收集表单数据
      2. 前端验证
      3. 后端验证
  */

  /**
   * 页面的初始数据
   */
  data: {
    // 账号--手机号
    phone: "",
    // 密码
    password: ""
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },
  // 表单项内容发生改变
  handleInput(event) {
    // let type = event.currentTarget.id; // id传值
    let type = event.currentTarget.dataset.type; // id传值
    this.setData({
      [type]: event.detail.value
    })
  },

  // 登录的回调
  async login() {
    let {
      phone,
      password
    } = this.data;
    // 前端验证
    if (!phone) {
      wx.showToast({
        title: '账号不能为空',
        icon: 'none'
      })
      return;
    }
    // 定义正则表达式
    let phoneReg = /^1(3|4|5|7|8|9)\d{9}$/;
    if (!phoneReg.test(phone)) {
      wx.showToast({
        title: '账号不存在',
        icon: 'error'
      })
      return;
    }

    if (!password) {
      wx.showToast({
        title: '密码不能为空',
        icon: 'none'
      })
      return;
    }

    let result = await request('/login/cellphone', {
      phone,
      password,
      isLogin: true
    });
    if (result.code === 200) {
      wx.showToast({
        title: '登录成功',
        icon: 'success'
      })

      // 将用户信息存储至本地
      wx.setStorageSync('userInfo', JSON.stringify(result.profile))

      // 跳转用户页面
      wx.reLaunch({
        url: '/pages/personal/personal',
      })
    } else if (result.code === 400) {
      wx.showToast({
        title: '账号不存在',
        icon: 'error'
      })
    } else if (result.code === 502) {
      wx.showToast({
        title: '密码错误',
        icon: 'error'
      })
    } else {
      wx.showToast({
        title: '登录失败',
        icon: 'error'
      })
    }
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})